草庐IT

sql - Golang 在 postgres 中包装查询执行

全部标签

ruby - 从 Ruby 中包含的文件访问变量

如何访问包含文件中定义的变量?#inc.rbfoo="bar";#main.rbrequire'inc.rb'putsfoo#NameError:undefinedlocalvariableormethod`foo'formain:Object 最佳答案 您无法访问其定义范围之外的本地文件——在本例中为文件。如果您想要跨文件边界的变量,请将它们设为局部变量。$foo、Foo和@foo都可以。如果你真的不想在符号上放置任何类型的装饰(可能因为你不喜欢它的读法),一个常见的hack就是将它定义为一个方法:deffoo()"bar"end

sql - 如何将嵌套集中的所有记录呈现为真正的 html 树

我正在使用awesome_nested_set我的Rails项目中的插件。我有两个看起来像这样的模型(简化):classCustomer:customer_idvalidates_presence_of:name#Furthervalidations...end数据库中的树按预期构建。parent_id的所有值,lft和rgt是正确的。树有多个根节点(这在awesome_nested_set中当然是允许的)。现在,我想在正确排序的树状结构中呈现给定客户的所有类别:例如嵌套标签。这不会太困难,但我需要它是高效的(sql查询越少越好)。更新:发现可以计算树中任何给定节点的子节点数,而无需进

ruby-on-rails - 如何在 Ruby on Rails 中执行期间确定 Controller 变量的值?

在执行期间确定Controller变量值的最佳方法是什么?例如,有没有办法在代码中插入一个中断,并使变量的值输出到屏幕(或日志)? 最佳答案 是的。最简单的方法是将值提升为字符串。像这样:raise@foo.to_s或者,您可以安装调试器(geminstallruby​​-debug),然后使用--debugger标志启动开发服务器。然后,在您的代码中,调用debugger指令。在调试器提示中,您有许多命令,包括打印变量值的p。更新:这里是abitmoreaboutruby-debug.

sql - Ruby on Rails Where 子句小于大于

所以我想做一个ruby​​onrails查询,它以这种方式构造,具有小于和大于约束。self.order('random()').where(friends:friend,age:{minimum:5,maximum:20})作为ruby​​初学者,以上是我想象的完成方式。但是,这不起作用。如何正确实现这一目标? 最佳答案 使用范围对象。.where(age:5..50)或者你可以这样写.where('ageBETWEEN5AND20') 关于sql-RubyonRailsWhere子句

ruby-on-rails - Rails/Ruby/Postgres - LoadError 无法加载此类文件 -- pg_ext

我正在尝试使用下面的railsController调用一个Ruby脚本(它连接到一个postgres数据库),但是它似乎在加载一个PGgem文件时遇到问题。我已经将我的require语句设置为需要'pg'并尝试了绝对路径(需要/usr/local/rvm/gems/ruby-1.9.3-p194@railsTest/gems/pg-0.14.0/库/pg/)。文件“pg_ext”实际上存在于目录中。此外,我可以毫无问题地独立运行ruby​​脚本(dbrubyscript.rb),但是当将rails添加到这个等式时,它会出现cannotloadsuchfile--pg_ext错误。这里的

ruby-on-rails - 奇怪的 ActiveRecord 问题——比如生成无效的 SQL

最近我们部署了一个新版本的应用程序,从那时起我们就发现ActiveRecord存在一些非常奇怪的问题。例如,这是它每天生成数百次的查询片段,通常是正确的:`entries`.`style`ASt1_r25,`entries`.`pdf_visibility`AS,`entries`.`web_visibility`ASt1_r27这不是打字错误,t1_r26不见了,虽然它应该在的地方有一个空格。但只有那一次。这也不是手写SQL,而是ActiveRecord编写查询并决定所有占位符变量。它同样拙劣地破坏了其他查询,将不应该留空(甚至不应该留空)的东西留空,但只是偶尔留空一次。大多数时候都

ruby-on-rails - 我不应该在 `included do ... end` block 中包含什么?

我正在使用RubyonRails3.2.2。我正在实现一个模块,并通过使用RoRActiveSupport::Concern将其包含在我的类(class)中特征。它使includeddo...endblock可用,使内部声明的代码在包含模块的类的类上下文中执行。我的疑问是:我应该不在includeddo...endblock中包含什么?也就是说,例如,是进行以下操作是一种“常见”/“良好”的做法吗?moduleMyModuleextendActiveSupport::ConcernclassMyModuleClassattr_accessor:attr1,:attr2,:attr3de

ruby - 传递给 `instance_exec` 时如何执行 proc

问题的灵感来自thisone.Proc::new有一个选项可以在方法内部没有block的情况下调用:Proc::newmaybecalledwithoutablockonlywithinamethodwithanattachedblock,inwhichcasethatblockisconvertedtotheProcobject.当proc/lambda实例作为代码块传递时,将创建Proc的新实例:Proc.singleton_class.prepend(Module.newdodefnew(*args,&cb)puts"PROC#{[block_given?,cb,*args].i

ruby - 从包含的文件中,如何获取执行包含的文件的文件名?

对于问题标题措辞不佳的道歉-不知道如何把它说得更好!在下面的代码中,当我执行rubybar.rb时,如何让它输出bar.rb,而不是foo.rb?在foo.rb中:moduleFoodeffilename__FILE__endend在bar.rb中:require_relative'foo'includeFooputsfilename#outputs'foo.rb'这是一个库函数,每次执行一些代码时,都会记录该代码的位置(和gitref)。 最佳答案 你的问题促使我打开Ruby解释器源代码,看看__FILE__是如何工作的。答案很有

ruby - 获取 Rails 项目中包含的所有 gem 的变更日志

我有一个使用bundler的Rails项目。我收录的许多gem都比最新可用的版本落后很多。我知道我可以祈祷并运行bundleupdate以将所有内容升级到最新版本,同时考虑到依赖性,但这可能会破坏我的应用程序中依赖已弃用gem方法的部分,可能不值得付出努力。有没有办法获取Gemfile.lock中设置的版本和ruby​​gems上的最新版本之间所有bundle的gem的变更日志?这似乎是一个相当普遍的需求,但我还没有'找到任何解决方案... 最佳答案 这真是个好主意。目前我还没有听说过有任何工具可以执行此操作,因此我创建了一个脚本来